草庐IT

C++ 指向类实例的指针

全部标签

pointers - 如何在双链表中获取元素值的指针(go-lang)

我想修改一个双链表中元素的值,但是不知道如何获取它的指针,因为元素的值是go-lang自己定义的一个nil接口(interface)。据我所知,我必须在获取元素的值之前进行类型断言,例如:val,ok:=ele.Value.(TYPE)ifok{//dosomething...}但如果我只是修改val,它就没有用了。那么有什么提示吗?谢谢。 最佳答案 有两个非常简单的选项。它们都将涉及类型断言,因为您正在使用interface{}您可以将其存储为指针并键入断言:varqinterface{}variintq=&i*(q.(*int)

go - 为什么包日志实例不能共享到 Golang 中的另一个包

我的项目有一些包,我不想将日志实例从一个函数传递到另一个函数,而是在包中使用全局日志实例。这是我完成的演示,但是运行gorunmain.go,logs/replica.log中没有任何打印。我的代码有什么问题?├──log│  └──replica.log├──logs│  └──logs.go├──main.go$catmain.gopackagemainimport("./logs")funcmain(){logs.Debug("hello")}$catlogs/logs.gopackagelogsimport(logging"github.com/op/go-logging""o

go - 由结构包装的 sql.DB 无法在实例中调用方法

我的目标是使用一个结构来包装sql.DB来做一些比sql.DB更重要的事情。我创建的实例无法运行,运行时出现此错误。DbConn.db.prepareundefined(cannotrefertounexportedfieldormethodsql.(*DB)."".prepare)我的代码是:typeDatabaseConnstruct{driverNamestringdatabaseNamestringuserNamestringpasswordstringdataSourceNamestringdb*sql.DB}func(dDatabaseConn)Open()error{d.

go - 将盒装结构转换到盒装指针 - golang

我正在为Golang使用Protobuf。Protobuf生成类型指针实现proto.Message()的消息类型。例如func(*SomeMessage)Message(){}protobuf库有类似Marshal(proto.Message)的方法现在谈谈我的实际问题。message:=SomeMessage{}SendMessage(&message)funcSendMessage(messageinterface{}){switchmsg:=message.(type){caseproto.Message://sendacrossthewireorwhateverdefault

go - 缺少指向静态库的链接

运行gorunmain.go我收到一条奇怪的错误消息:danilo@lm~/godev/src/quick$gorunmain.gocommand-line-arguments/usr/lib/go-1.6/pkg/tool/linux_amd64/link:cannotopenfile/usr/lib/go-1.6/pkg/linux_amd64/github.com/valyala/quicktemplate.a:open/usr/lib/go-1.6/pkg/linux_amd64/github.com/valyala/quicktemplate.a:nosuchfileordi

go - 如何在 Golang 中正确初始化结构中的结构指针

这个问题在这里已经有了答案:HowcanIinitializeatypethatisapointertoastructinGo?(1个回答)关闭上个月。我有一个生成的结构,如下所示:typea_weird_structstruct{a*stringb*stringc*struct{d*inte*intf*int}}初始化这个结构的正确方法是什么?具体来说,结构指针c。

json - 将嵌套接口(interface){}解码为用户提供的结构指针

我有一个Set函数,它在我自己的名为session的结构中包装了一个用户对象(或变量)。它将它分配给我的session结构的值字段。然后Set函数编码此结构并将字符串分配到存储中的某处。我的问题是我不确定如何实现我的Get函数以仅返回存储在值字段中的未编码结构,而不是整个session包装器结构。我做了一个非常简单的example证明我在说什么。我无法在Get函数的赋值中使用类型断言,因为我事先不知道用户将使用什么类型。我怀疑可能有一种方法可以使用反射来实现这一点?编辑:目前提供的两个答案不是我要找的。我不知道用户将使用什么类型,它可能是任何类型,因此通过硬编码他们的类型或试图“猜测”

CGO 我正在传递一个 C 结构,它带有一个指向 go 函数的值的指针,

我很疑惑下面的场景是否需要清理内存?我有一个C函数,它创建一个C结构并将其传递给Go函数。C结构包含一个值数组(使用指针算法)。Go函数填充此数组并返回。在调用C函数中,我将值从C结构中复制出来并且不存储它们。因为这是在Go中创建的,所以垃圾会被收集吗?/*Ccode*/intgo_func(c_struct*s);structc_struct{val*values;size_t*values_cnt;};voidexample_call(){structc_structs;go_func(&s)copy_values(s)}/*gocode*/funcgo_func(c*C.c_st

json - 具有非简单类型的 GoLang JSON Marshal omitempty - 可以避免指针吗?

下面的代码是解释。我可以使用非简单类型的唯一方法是使该类型成为指针。是否有不使用指针的替代解决方案?代码不工作:typeFoostruct{BarBar`json:"bar,omitempty"`}typeBarstruct{Bazstring`json:"baz"`}funcmain(){foo:=Foo{}jsonBytes,_:=json.Marshal(foo)fmt.Printf("%s\n",jsonBytes)}输出:{"bar":{"baz":""}}代码工作,但不是我想要的:typeFoostruct{Bar*Bar`json:"bar,omitempty"`}typ

go - 什么是 cgo 类型,相当于指向结构的 const 指针?

我在C中定义了一个外部函数://externvoidgoCallback(conststructlibvlc_event_t*,void*);在go中定义://exportgoCallbackfuncgoCallback(eventunsafe.Pointer,userDataunsafe.Pointer){log.Fatal("TODOgoCallback")}编译代码时出现类型冲突错误#github.com/tarrsalah/libvlc-goInfileincludedfrom$WORK/github.com/tarrsalah/libvlc-go/_obj/_cgo_expo